# MIPS Reference Data

1

| CORE INSTRUCTION               |                              |                              |                                                                                                                                                                         |         | OPCODE                |
|--------------------------------|------------------------------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------------------|
| NAME, MNEMO                    |                              | FOR-<br>MAT                  | OPERATION (in Verilog)                                                                                                                                                  |         | / FUNCT<br>(Hex)      |
| Add                            | add                          | R                            | R[rd] = R[rs] + R[rt]                                                                                                                                                   | (1)     | 0 / 20 <sub>hex</sub> |
| Add Immediate                  | addi                         | I                            | R[rt] = R[rs] + SignExtImm                                                                                                                                              | (1,2)   | 8 <sub>hex</sub>      |
|                                | addiu                        | I R[rt] = R[rs] + SignExtImm |                                                                                                                                                                         | (2)     | 9 <sub>hex</sub>      |
| Add Unsigned                   | addu                         | R  R[rd] = R[rs] + R[rt]     |                                                                                                                                                                         | (-)     | 0 / 21 <sub>hex</sub> |
| And                            | and                          | R                            | R[rd] = R[rs] & R[rt]                                                                                                                                                   |         | 0 / 24 <sub>hex</sub> |
| And Immediate                  | andi                         | I                            | R[rt] = R[rs] & ZeroExtImm                                                                                                                                              | (3)     | c <sub>hex</sub>      |
| Branch On Equal                | beq                          | I                            | if(R[rs]==R[rt])<br>PC=PC+4+BranchAddr                                                                                                                                  | (4)     | 4 <sub>hex</sub>      |
| Branch On Not Equal            | bne                          | I                            | if(R[rs]!=R[rt])<br>PC=PC+4+BranchAddr                                                                                                                                  | (4)     | 5 <sub>hex</sub>      |
| Jump                           | j                            | J                            | PC=JumpAddr                                                                                                                                                             | (5)     | $2_{\text{hex}}$      |
| Jump And Link                  | jal                          | J                            | R[31]=PC+8;PC=JumpAddr                                                                                                                                                  | (5)     | $3_{\text{hex}}$      |
| Jump Register                  | jr                           | R                            | PC=R[rs]                                                                                                                                                                |         | 0 / 08 <sub>hex</sub> |
| Load Byte Unsigned             | lbu                          | I                            | R[rt]={24'b0,M[R[rs]<br>+SignExtImm](7:0)}                                                                                                                              | (2)     | $24_{\text{hex}}$     |
| Load Halfword<br>Unsigned      | lhu                          | I                            | R[rt]={16'b0,M[R[rs]<br>+SignExtImm](15:0)}                                                                                                                             | (2)     | 25 <sub>hex</sub>     |
| Load Linked                    | 11                           | I                            | R[rt] = M[R[rs] + SignExtImm]                                                                                                                                           | (2,7)   | $30_{\text{hex}}$     |
| Load Upper Imm.                | lui                          | I                            | $R[rt] = \{imm, 16'b0\}$                                                                                                                                                |         | $f_{hex}$             |
| Load Word                      | lw                           | I                            | R[rt] = M[R[rs] + SignExtImm]                                                                                                                                           | (2)     | $23_{\rm hex}$        |
| Nor                            | nor                          | R                            | $R[rd] = \sim (R[rs] \mid R[rt])$                                                                                                                                       |         | $0/27_{hex}$          |
| Or                             | or                           | R                            | $R[rd] = R[rs] \mid R[rt]$                                                                                                                                              |         | 0 / 25 <sub>hex</sub> |
| Or Immediate                   | ori                          | I                            | $R[rt] = R[rs] \mid ZeroExtImm$                                                                                                                                         | (3)     | $d_{hex}$             |
| Set Less Than                  | slt                          | R                            | R[rd] = (R[rs] < R[rt]) ? 1 : 0                                                                                                                                         |         | 0 / 2a <sub>hex</sub> |
| Set Less Than Imm.             | slti                         | I                            | $R[rt] = (R[rs] \le SignExtImm)? 1$                                                                                                                                     | : 0 (2) | a <sub>hex</sub>      |
| Set Less Than Imm.<br>Unsigned | sltiu                        | I                            | R[rt] = (R[rs] < SignExtImm) ? 1:0                                                                                                                                      | (2,6)   | $b_{\text{hex}}$      |
| Set Less Than Unsig.           | sltu                         | R                            | R[rd] = (R[rs] < R[rt]) ? 1 : 0                                                                                                                                         | (6)     | 0 / 2b <sub>hex</sub> |
| Shift Left Logical             | sll                          | R                            | $R[rd] = R[rt] \le shamt$                                                                                                                                               |         | 0 / 00 <sub>hex</sub> |
| Shift Right Logical            | srl                          | R                            | R[rd] = R[rt] >>> shamt                                                                                                                                                 |         | 0 / 02 <sub>hex</sub> |
| Store Byte                     | sb                           | I                            | M[R[rs]+SignExtImm](7:0) = R[rt](7:0)                                                                                                                                   | (2)     | 28 <sub>hex</sub>     |
| Store Conditional              | sc                           | I                            | M[R[rs]+SignExtImm] = R[rt]; $R[rt] = (atomic) ? 1 : 0$                                                                                                                 | (2,7)   | 38 <sub>hex</sub>     |
| Store Halfword                 | sh                           | I                            | M[R[rs]+SignExtImm](15:0) = R[rt](15:0)                                                                                                                                 | (2)     | 29 <sub>hex</sub>     |
| Store Word                     | SW                           | I                            | M[R[rs]+SignExtImm] = R[rt]                                                                                                                                             | (2)     |                       |
| Subtract                       | sub                          | R                            | R[rd] = R[rs] - R[rt]                                                                                                                                                   | (1)     | 0 / 22 <sub>hex</sub> |
| Subtract Unsigned              | subu                         | R                            | R[rd] = R[rs] - R[rt]                                                                                                                                                   |         | 0 / 23 <sub>hex</sub> |
|                                | (2) Sig<br>(3) Ze<br>(4) Bra | gnExtl<br>roExtl<br>anchA    | se overflow exception<br>imm = { 16{immediate[15]}, imm<br>imm = { 16{1b'0}, immediate }<br>iddr = { 14{immediate[15]}, immediate }<br>dr = { PC+4[31:28], address, 2't | ediate, |                       |

- (5) JumpAddr = { PC+4[31:28], address, 2'b0 }(6) Operands considered unsigned numbers (vs. 2's comp.)
- (7) Atomic test&set pair; R[rt] = 1 if pair atomic, 0 if not atomic

# BASIC INSTRUCTION FORMATS

| 1  | opcode    | е    |      | rs       |      | rt       | 0   | rd      | shamt       | fun      | ct   |
|----|-----------|------|------|----------|------|----------|-----|---------|-------------|----------|------|
|    | 31        | 26   | 25   | 21       | 20   | 16       | 15  | 11      | 10          | 6 5      | 0    |
|    | opcod     | е    |      | rs       |      | rt       |     |         | immedia     | te       |      |
|    | 31        | 26   | 25   | 21       | 20   | 16       | 15  |         |             |          | 0    |
|    | opcod     | e    |      |          |      |          | ad  | dress   |             |          |      |
|    | 31        | 26   | 25   |          |      |          |     |         |             |          | 0    |
| 20 | 14 by Ele | ovie | r Ir | oc A11 r | ahte | recerved | Fro | m Patte | erson and I | Jennessy | Comp |

# ARITHMETIC CORE INSTRUCTION SET

|                                   |        |      | o .                                                             | / FMT /FT |
|-----------------------------------|--------|------|-----------------------------------------------------------------|-----------|
|                                   |        | FOR- |                                                                 | / FUNCT   |
| NAME, MNEMO                       |        | MAT  |                                                                 | (Hex)     |
| Branch On FP True                 |        | FI   | if(FPcond)PC=PC+4+BranchAddr (4)                                | 11/8/1/   |
| Branch On FP False                | bc1f   | FI   | if(!FPcond)PC=PC+4+BranchAddr(4)                                | 11/8/0/   |
| Divide                            | div    | R    | Lo=R[rs]/R[rt]; Hi=R[rs]%R[rt]                                  | 0//-1a    |
| Divide Unsigned                   | divu   | R    | Lo=R[rs]/R[rt]; Hi=R[rs]%R[rt]  (6)                             | 0///1b    |
| FP Add Single                     | add.s  | FR   | F[fd] = F[fs] + F[ft]                                           | 11/10//0  |
| FP Add                            | add.d  | FR   | ${F[fd],F[fd+1]} = {F[fs],F[fs+1]} +$                           | 11/11//0  |
| Double                            |        |      | {F[ft],F[ft+1]}                                                 |           |
| FP Compare Single                 | c.x.s* | FR   | FPcond = (F[fs] op F[ft]) ? 1 : 0                               | 11/10//y  |
| FP Compare                        | c.x.d* | FR   | $FPcond = (\{F[fs], F[fs+1]\} op$                               | 11/11//v  |
| Double                            |        |      | {F[ft],F[ft+1]})?1:0                                            |           |
|                                   |        |      | ==, <, or <=) (y is 32, 3c, or 3e)                              | 11/10//3  |
| FP Divide Single                  | div.s  | FK   | F[fd] = F[fs] / F[ft]                                           | 11/10//3  |
| FP Divide                         | div.d  | FR   | ${F[fd],F[fd+1]} = {F[fs],F[fs+1]} /$                           | 11/11//3  |
| Double                            |        | ED   | {F[ft],F[ft+1]}                                                 | 11/10//2  |
| FP Multiply Single                | mul.s  | FR   | F[fd] = F[fs] * F[ft] $(F[fd] = F[fd+1]) = (F[fd] + F[fd+1]) *$ | 11/10//2  |
| FP Multiply<br>Double             | mul.d  | FR   | ${F[fd],F[fd+1]} = {F[fs],F[fs+1]} * {F[ft],F[ft+1]}$           | 11/11//2  |
| FP Subtract Single                | sub.s  | FR   | {F[fd]=F[fs] - F[ft]                                            | 11/10//1  |
| FP Subtract Single<br>FP Subtract | sub.s  | rĸ   | $\{F[fd],F[fd+1]\} = \{F[fs],F[fs+1]\}$                         |           |
| Double                            | sub.d  | FR   | {F[fd],F[fd+1]} - {F[fs],F[fs+1]} - {F[ft],F[ft+1]}             | 11/11//1  |
| Load FP Single                    | lwc1   | Ι    | F[rt]=M[R[rs]+SignExtImm]  (2)                                  | 31//      |
| Load FP Single                    | IWCI   |      | F[rt]=M[R[rs]+SignExtImm]; (2)                                  |           |
| Double                            | ldc1   | I    | F[rt+1]=M[R[rs]+SignExtImm+4]                                   | 35//      |
| Move From Hi                      | mfhi   | R    | R[rd] = Hi                                                      | 0 ///10   |
| Move From Lo                      | mflo   | R    | R[rd] = Lo                                                      | 0 ///12   |
| Move From Control                 |        | R    | R[rd] = CR[rs]                                                  | 10 /0//0  |
| Multiply                          | mult   | R    | $\{Hi,Lo\} = R[rs] * R[rt]$                                     | 0///18    |
| Multiply Unsigned                 |        | R    | $\{Hi,Lo\} = R[rs] * R[rt] $ $(6)$                              |           |
| Shift Right Arith.                | sra    | R    | R[rd] = R[rt] >> shamt                                          | 0///3     |
| Store FP Single                   | swc1   | I    | M[R[rs]+SignExtImm] = F[rt] (2)                                 |           |
| Store FP                          | 0.01   |      | M[R[rs]+SignExtImm] = F[rt]; (2)                                |           |
| Double                            | sdcl   | I    | M[R[rs]+SignExtImm+4] = F[rt+1]                                 | 3d//      |
| Dodoic                            |        |      | minimize of generalities of a fire of                           |           |

OPCODE

## FLOATING-POINT INSTRUCTION FORMATS

| FR |    | opcode | fmt |    | ft |    | fs    | fd        | funct |
|----|----|--------|-----|----|----|----|-------|-----------|-------|
|    | 31 | 26     | 25  | 21 | 20 | 16 | 15 11 | 10 6      | 5 0   |
| FI |    | opcode | fmt |    | ft |    |       | immediate | •     |
|    | 31 | 26     | 25  | 21 | 20 | 16 | 15    |           | 0     |

## **PSEUDOINSTRUCTION SET**

| NAME                         | <b>MNEMONIC</b> | OPERATION                        |
|------------------------------|-----------------|----------------------------------|
| Branch Less Than             | blt             | $if(R[rs] \le R[rt]) PC = Label$ |
| Branch Greater Than          | bgt             | if(R[rs]>R[rt]) PC = Label       |
| Branch Less Than or Equal    | ble             | $if(R[rs] \le R[rt]) PC = Label$ |
| Branch Greater Than or Equal | bge             | $if(R[rs] \ge R[rt]) PC = Label$ |
| Load Immediate               | li              | R[rd] = immediate                |
| Move                         | move            | R[rd] = R[rs]                    |
|                              |                 |                                  |

## REGISTER NAME, NUMBER, USE, CALL CONVENTION

| NAME      | NUMBER | USE                                                      | PRESERVED ACROSS<br>A CALL? |
|-----------|--------|----------------------------------------------------------|-----------------------------|
| \$zero    | 0      | The Constant Value 0                                     | N.A.                        |
| \$at      | 1      | Assembler Temporary                                      | No                          |
| \$v0-\$v1 | 2-3    | Values for Function Results<br>and Expression Evaluation | No                          |
| \$a0-\$a3 | 4-7    | Arguments                                                | No                          |
| \$t0-\$t7 | 8-15   | Temporaries                                              | No                          |
| \$s0-\$s7 | 16-23  | Saved Temporaries                                        | Yes                         |
| \$t8-\$t9 | 24-25  | Temporaries                                              | No                          |
| \$k0-\$k1 | 26-27  | Reserved for OS Kernel                                   | No                          |
| \$gp      | 28     | Global Pointer                                           | Yes                         |
| \$sp      | 29     | Stack Pointer                                            | Yes                         |
| \$fp      | 30     | Frame Pointer                                            | Yes                         |
| \$ra      | 31     | Return Address                                           | Yes                         |

